home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Personal Computer World 2009 February
/
PCWFEB09.iso
/
Software
/
Freeware
/
Griffith 0.9.8
/
griffith-0.9.8-win32.exe
/
{app}
/
lib
/
plugins
/
movie
/
PluginMovieIMDB-es.py
< prev
next >
Wrap
Text File
|
2008-11-17
|
6KB
|
160 lines
# -*- coding: iso-8859-15 -*-
__revision__ = '$Id: PluginMovieIMDB-es.py 389 2006-07-29 18:43:35Z piotrek $'
# Copyright (c) 2006 Pedro D. Sßnchez
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Library General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
# You may use and distribute this software under the terms of the
# GNU General Public License, version 2 or later
import gutils
import movie
import string
plugin_name = 'IMDb-es'
plugin_description = 'Internet Movie Database Spanish'
plugin_url = 'spanish.imdb.com'
plugin_language = _('Spanish')
plugin_author = 'Pedro D. Sßnchez'
plugin_author_email = '<pedrodav@gmail.com>'
plugin_version = '0.2'
class Plugin(movie.Movie):
def __init__(self, id):
self.encode='iso-8859-15'
self.movie_id = id
self.url = "http://spanish.imdb.com/title/tt%s" % str(self.movie_id)
def get_image(self):
tmp = string.find(self.page, 'a name="poster"')
if tmp == -1: # poster not available
self.image_url = ''
else:
self.image_url = gutils.trim(self.page[tmp:], 'src="', '"')
def get_o_title(self):
self.o_title = gutils.trim(self.page, '<strong class="title">', ' <small>')
def get_title(self):
tmp = 0
tmpTot = 0
while (tmp <> -1):
auxTitle = ''
tmp = string.find(self.page[tmpTot:], '<i class="transl">')
if tmp <> -1:
auxTitle = gutils.trim(self.page[tmpTot:], '<i class="transl">', '</i>')
if string.find(auxTitle, '(Spain)') <> -1:
auxTitle = string.replace(auxTitle, ' ', ' ')
auxTitle = string.replace(auxTitle, ' (Argentina) ', '')
auxTitle = string.replace(auxTitle, ' (Spain) ', '')
auxTitle = string.replace(auxTitle, ' (Mexico) ', '')
auxTitle = string.replace(auxTitle, ' [es]', '')
tmp = -1
tmpTot = tmpTot + tmp + 1
if auxTitle <> '':
self.title = auxTitle
else:
self.title = self.o_title
def get_director(self):
self.director = gutils.trim(self.page,'Dirigida por</b><br>', '<br>')
def get_plot(self):
self.plot = gutils.trim(self.page, '<b class="ch">Resumen', '<a href="/rg/title-tease/plot')
self.plot = gutils.after(self.plot, ':</b> ')
def get_year(self):
self.year = gutils.trim(self.page, '<a href="/Sections/Years/', '</a>)</small>')
self.year = gutils.after(self.year, '">')
def get_runtime(self):
self.runtime = gutils.trim(self.page, '<b class="ch">Duraci≤n:</b>', ' min')
if self.runtime == '':
self.runtime = gutils.trim(self.page, '<b class="ch">Duración:</b>', ' min')
def get_genre(self):
self.genre = gutils.trim(self.page, '<a href="/Sections/Genres/', '<br>')
self.genre = gutils.after(self.genre, '/">')
self.genre = string.replace(self.genre, '(mßs)', '')
self.genre = string.replace(self.genre, '(más)', '')
def get_cast(self):
self.cast = ''
self.cast = gutils.trim(self.page, 'Cast overview, first billed only:', '<a href="fullcredits">')
if (self.cast==''):
self.cast = gutils.trim(self.page, 'cast: ','<a href="fullcredits">')
self.cast = string.replace(self.cast, ' .... ', _(' as '))
self.cast = string.replace(self.cast, '</tr><tr>', "\n")
self.cast = string.replace(self.cast, '</tr><tr bgcolor="#FFFFFF">', "\n")
self.cast = string.replace(self.cast, '</tr><tr bgcolor="#F0F0F0">', "\n")
self.cast = string.strip(gutils.strip_tags(self.cast))
def get_classification(self):
self.classification = gutils.trim(self.page, '<a href="/List?certificates=Spain:', '</a>')
self.classification = gutils.after(self.classification, '">Spain:')
#self.classification = gutils.trim(self.page, 'MPAA</a>:</b> ', '<br>')
#self.classification = ''
def get_studio(self):
self.studio = ''
def get_o_site(self):
self.o_site = ''
def get_site(self):
self.site = "http://spanish.imdb.com/title/tt%s" % self.movie_id
def get_trailer(self):
self.trailer = "http://spanish.imdb.com/title/tt%s/trailers" % self.movie_id
def get_country(self):
self.country = gutils.trim(self.page, '<b class="ch">Paφs:</b>', '</a>')
if self.country == '':
self.country = gutils.trim(self.page, '<b class="ch">País:</b>', '</a>')
self.country = gutils.after(self.country, '/">')
def get_rating(self):
self.rating = gutils.trim(self.page, '<b class="ch">Calificaci≤n de los usuarios:</b>', '/10</b> (')
if self.rating == '':
self.rating = gutils.trim(self.page, '<b class="ch">Calificación de los usuarios:</b>', '/10</b> (')
if self.rating:
self.rating = str(float(gutils.clean(self.rating)))
class SearchPlugin(movie.SearchMovie):
def __init__(self):
self.original_url_search = 'http://spanish.imdb.com/find?more=tt;q='
self.translated_url_search = 'http://spanish.imdb.com/find?more=tt;q='
self.encode = 'iso-8859-15'
def search(self,parent_window):
self.open_search(parent_window)
self.sub_search()
return self.page
def sub_search(self):
self.page = gutils.trim(self.page, '</b> found the following results:', '<b>Suggestions For Improving Your Results</b>');
self.page = self.page.decode('iso-8859-15')
def get_searches(self):
elements = string.split(self.page, '<li>')
if (elements[0]<>''):
for element in elements:
self.ids.append(gutils.trim(element, '/title/tt','/?fr='))
self.titles.append(gutils.strip_tags(gutils.convert_entities(gutils.trim(element, ';fm=1">', '</li>'))))